package com.black.system.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.black.common.core.domain.entity.SysDept;
import com.black.system.domain.req.system.add.SysDeptAddReq;
import com.black.system.domain.req.system.edit.SysDeptEditReq;
import com.black.system.domain.req.system.query.SysDeptQueryReq;
import com.black.system.domain.resp.system.SysDeptEditQueryResp;
import com.black.system.domain.resp.system.SysDeptResp;
import com.black.system.domain.resp.system.SysDeptTreeResp;

import java.util.List;

/**
 * @author L
 * @description 针对表【sys_dept(部门表)】的数据库操作Service
 * @createDate 2024-08-19 10:07:23
 */
public interface SysDeptService extends IService<SysDept> {

    /**
     * 查询部门列表
     *
     * @param req
     * @return
     */
    List<SysDeptResp> search(SysDeptQueryReq req);

    /**
     * 新增部门
     *
     * @param req
     * @return
     */
    boolean add(SysDeptAddReq req);

    /**
     * 根据id删除部门
     *
     * @param id
     * @return
     */
    boolean deleteById(Long id);

    /**
     * 根据id查询部门
     *
     * @param id
     * @return
     */
    SysDeptEditQueryResp findById(Long id);

    /**
     * 修改部门
     *
     * @param req
     * @return
     */
    boolean edit(SysDeptEditReq req);

    /**
     * 排除指定ID及子节点的部门列表
     *
     * @param req
     * @return
     */
    List<SysDeptResp> excludeList(SysDeptQueryReq req);

    /**
     * 获取部门树
     * @param sysDeptQueryReq
     * @return
     */
    List<SysDeptTreeResp> allDeptTree(SysDeptQueryReq sysDeptQueryReq);
}
